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A HEADER COMPRESS/DECOMPRESS FRAMEWORK 
BACKGROUND 

[0001] Various header compression mechanisms to reduce header overhead of 
packets transmitted over a network (e.g., Internet) have been introduced in 

5 recent years. For example, header compressions under compressed transfer 
control protocol (CTCP), compressed real time transport protocol (CRTP) and 
robust header compression (ROHC) have been widely used, especially, in 
voice over internet protocol (VoIP) applications. However, those header 
compression mechanisms are designed for specific networks or traditional 

1 0 usage models, regardless of changeable network environment, different types 
of the packets, user's preference for header compression and the like. Same 
situations exist in header decompression for the packets received through the 
network. 

BRIEF DESCRIPTION OF THE DRAWINGS 

* 

1 5[0002] The invention described herein is illustrated by way of example and not by 
way of limitation in the accompanying figures. For simplicity and clarity of 
illustration, elements illustrated in the figures are not necessarily drawn to 
scale. For example, the dimensions of some elements may be exaggerated 
relative to other elements for clarity. Further, where considered appropriate, 

20 reference labels have been repeated among the figures to indicate 
corresponding or analogous elements. 
[0003] Fig. 1 shows an embodiment of a communication system comprising a 
header compress/decompress framework. 
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[0004] Fig. 2 shows an embodiment of an internet protocol (IP) based terminal or 
IP device having the header compress/decompress framework in the 

* 

communication system of Fig. 1 . 
[0005] Fig. 3 shows an embodiment of the header compress/decompress 

5 framework of Fig. 1. 

[0006] Fig. 4 shows an embodiment of a header compression/decompression 
method implemented by the header compress/decompress framework of Fig. 

3. 

DETAILED DESCRIPTION 

1 0[0007] The following description describes techniques for header 

compression/decompression method and apparatus. In the following 
description, numerous specific details such as logic implementations, pseudo- 
code, means to specify operands, resource partitioning/sharing/duplication 
implementations, types and interrelationships of system components, and logic 

1 5 partitioning/integration choices are set forth in order to provide a more 

thorough understanding of the current invention. However, the invention may 
be practiced without such specific details. In other instances, control 
structures, gate level circuits and full software instruction sequences have not 
been shown in detail in order not to obscure the invention. Those of ordinary 

20 skill in the art, with the included descriptions, will be able to implement 
appropriate functionality without undue experimentation. 
[0008] References in the specification to "one embodiment", "an embodiment", "an 
example embodiment", etc., indicate that the embodiment described may 
include a particular feature, structure, or characteristic, but every embodiment 
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may not necessarily include the particular feature, structure, or characteristic. 
Moreover, such phrases are not necessarily referring to the same 
embodiment. Further, when a particular feature, structure, or characteristic is 
described in connection with an embodiment, it is submitted that it is within the 
5 knowledge of one skilled in the art to effect such feature, structure, or 

characteristic in connection with other embodiments whether or not explicitly 
described. 

[0009] Embodiments of the invention may be implemented in hardware, firmware, 
software, or any combination thereof. Embodiments of the invention may also 

10 be implemented as instructions stored on a machine-readable medium, that 
may be read and executed by one or more processors. A machine-readable 
medium may include any mechanism for storing or transmitting information in a 
form readable by a machine (e.g., a computing device). For example, a 
machine-readable medium may include read only memory (ROM); random 

15 access memory (RAM); magnetic disk storage media; optical storage media; 
flash memory devices; electrical, optical, acoustical or other forms of 
propagated signals (e.g., earner waves, infrared signals, digital signals, etc.) 
and others. 

[001 0] An embodiment of a communication system 1 0 comprising a header 
20 compress/decompress framework is shown in Fig. 1 . The communication 

system 10 may comprise endpoints 1 1 and 12 that may communicate through 
an IP based network 14, such as Internet or private LAN. Each endpoint 11/12 
may further comprise various types of terminals, such as IP based terminals 
1 1 1/121 for communication through the network 14 with IP packet 
25 coding/decoding implemented by itself, or non-IP based terminals 1 12/122 for 
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communication through the network 14 with IP packet coding/decoding 
implemented by an IP device 1 13/123. Examples for the IP based terminals 
1 11/121 may comprise IP phone, IP fax machine, personal digital assistant 
(PDA), mainframe computer, mini-computer, personal computer, portable 

5 computer, laptop computer and other devices for transceiving and processing 
IP packets, etc. Examples for the non-IP based terminals may comprise 
conventional telephone, fax machine, cell phone, and other devices for 
transceiving and processing non-IP packets, etc. The conventional telephone 
and fax machine may further link with the IP device 1 13/123 through a public 

1 0 switched telephone network (PSTN), and the cell phone may further link with 
the IP device 113/123 through a wireless network. Each terminal- in the 
endpoint 11 may be of bidirectional communication with any terminal in the 
endpoint 12 through audio, video and data. 
[001 1] The IP device 1 13/123 may enable the bidirectional communication for the 

1 5 non-IP based terminals 1 12/122 by coding audio, video and data samples 
received from the non-IP based terminals 1 12/122 into IP packets to be 
transmitted through the network 14 or decoding IP packets received through 
the network 14 into the audio, video and data samples to be transmitted to the 
non-IP based terminals 1 12/122. Examples for the IP device 1 13/123 may 

20 comprise a gateway, modem, etc. 

[0012] In accordance with the embodiment, the IP based terminal 1 1 1/121 and the 
IP device 1 1 3/123 may respectively comprise a frame constructor/extractor 
100A, 100B, 100C and 100D to construct audio, video and data frames into IP 
packets or extract audio, video and data frames from the IP packets, and a 

25 header compress/decompress framework 101A, 101B, 101C and 101D 

4 



WO 2007/065300 PCT/CN2005/002133 

coupled between the frame constructor/extractor 100 and the network 14 to 
make a header policy based upon various factors and compress or 
decompress headers of the IP packets received from the frame 
constructor/extractor or from the network based upon the header policy, Many 
5 factors may influence the policy making and thus change the header 

compression/decompression process, such as network environment, types of 
the IP packets, user preferences on header compression/decompression, 
predefined rules on header compression/decompression, and so on. 
[001 3] The header policy may determine whether or not to compress/decompress 

10 a header of an IP packet input to the framework 101. The header policy may 
further adjust an existing header compression/decompression mechanism that 
the framework 1 01 may adopt to compress/decompress the IP packet 
headers, such as how many IP packets with static header fields should be 
send out before starting the header compression, how to compress 

1 5 'predictable' header fields, and the like. The header policy may further 
determine how to process the IP packet after header 
compression/decompression, for example, whether to discard the IP packet. 
[0014] Fig. 2 depicts an embodiment of the IP based terminals 1 1 1/121 or IP 
device 113/123 in Fig. 1. 

20[0015] In accordance with the embodiment, the IP based terminals 1 1 1/121 or IP 
device 1 13/123 may comprise one or more processors 20, memory 21 , chipset 
22, I/O device 23, BIOS firmware 24 and the like. The one or more processors 
20 are communicatively coupled to various components (e.g., the memory 21 ) 
via one or more buses such as a processor bus. The processors 20 may be 

25 implemented as an integrated circuit (IC) with one or more processing cores 
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that may execute codes under a suitable architecture, for example, including 
Intel® Pentium™, Intel® XScale™ architectures, available from Intel 
Corporation of Santa Clara, California. 
[0016] In an embodiment, the memory 21 may store codes to be executed by the 

5 processor 20. A non-exhaustive list of examples for the memory 21 may 

comprise one or a combination of the following semiconductor devices, such 
as synchronous dynamic random access memory (SDRAM) devices, 
RAMBUS dynamic random access memory (RDRAM) devices, double data 
rate (DDR) memory devices, static random access memory (SRAM), flash 

10 memory devices, and the like. 
[001 7] In an embodiment, the chipset 22 may provide one or more communicative 
path among the processor20, memory 21 and various components, such as 
the I/O device 23 and BIOS firmware 24. The chipset 22 may comprise a 
memory controller hub 220, an input/output controller hub 221 and a firmware 

15 hub 222. 

[001 8] In an embodiment, the memory controller hub 220 may provide a 

communication link to the processor bus that may connect with the processor 

20 and to a suitable device such as the memory 21 . The memory controller 

hub 220 may couple with the I/O controller hub 221 that may provide an 

20 interface to the I/O devices 23. A non-exhaustive list of examples for the I/O 

devices 23 of the IP based terminals 111/121 may comprise a network card 

connecting to the network 14, audio device and audio controller to 

capture/display audio samples, graphic device and graphic controller to 

capture/display video samples, etc. A non-exhaustive list of examples for the 

25 I/O devices 23 of the IP device 1 13/123 may comprise a network card 
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connecting to the network 14, an interface connecting to the non-IP based 
terminal 1 12/122 such as a fixed phone line connecting to the conventional 
telephone or fax machine, a D/A converter to convert analogue signals 
received from the non-IP based terminal 112/1 22 into digital signals to be 
5 transmitted over the network 14 or convert the digital signals received through 
the network 14 into the analogue signals to be transmitted to the non-IP based 

terminal 1 12/122, and so on. 
[001 9] In an embodiment, the memory controller hub 220 may communicatively 
couple with a firmware hub 222 via the input/output controller hub 221 . The 
1 o firmware hub 222 may couple with the BIOS firmware 24 that may store 

routines that the computing platform executes during system startup in order to 
initialize the processors 20, chipset 22, and other components of the IP based 

platform or IP device. 
[0020] In the embodiment as depicted in Fig. 2, the memory 21 may further store 
1 5 software images as the frame constructor/extractor 1 00 and the header 

compress/decompress framework 1 01 . 
[0021 ] Fig. 3 depicts an embodiment of the header compress/decompress 

framework 101 in Fig. 1. 
[0022] In accordance with the embodiment, the header compress/decompress 
20 framework 1 01 may comprise a policy agent 31 , a filter configuration logic 32, 
an upper traffic filter 33, an upper configuration filter 34, a lower traffic filter 35, 
a lower configuration filter 36 and a compress/decompress logic 37. 
[0023] The policy agent 31 may make a header policy base upon various factors, 
such as characteristics of the network and/or IP packets, user's preference for 
25 header compression/decompression, predefined rules on header 
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compression/decompression, feedback on header 
compression/decompression for previous IP packets, etc. The policy agent 
may further comprise a factor collector 310 to collect the factors that may 
influence the policy making, and a policy maker 314 to make a header policy 
5 based upon the collected factors. The factor collector 310 may further 

comprise a sensor 31 1 to sense the characteristics of the network and/or IP 
packets, a user interface 312 to interact with a user of the IP based terminals 
1 1 1/121 or non-IP based terminals 1 12/122 and collect user's preference for 
header compression/decompression and a predefined rule database 313 setup 

1 0 during a configuration phase of the header compress/decompress framework 
101 to store predefined rules on header compression/decompression. 
[0024] The sensor 31 1 may sense the characteristics of the network and/or IP 
packets including, but not limited to, network type, bandwidth, transmission 
speed, type of a network device that may route the IP packets output from the 

15 header compress/decompress framework 1 01 , type of IP packets, etc. For 
example, the sensor 311 may sense whether the network is a fixed wired 
network (e.g., 802.3 based wired Ethernet) or a wireless network (e.g., 802.11 
based WiFi connection) as well as the bandwidth and/or transmission speed, 
so as to help the policy maker 314 determine whether the network is stable 

20 and high speed or unstable and low speed. For another example, the sensor 
31 1 may sense whether the network device routing the IP packets output from 
the header compress/decompress framework 101 is aware of header 
compression and/or type of the IP packets (e.g., audio packets or video 
packet) so as to help the policy maker 314 determine whether the header 

25 compression is necessary. 
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[0025] The user interface 31 2 may provide a graphic interface to interact with user 
of the IP based terminals 111/121 or non-IP based terminals 112/122 and 
collect user's preference for header compression/decompression so as to help 
the policy maker 314 make a corresponding header policy. For example, the 
5 user interface 312 may collect information on whether or not the user prefers 
headers of specific IP packets (e.g., the IP packets from/to a specific 
caller/recipient or transceived in a specific period of time) to be compressed or 
decompressed. The user interface 312 may further collect information on how 
the user prefers the headers of the IP packets to be compressed or 

10 decompressed, e.g., proactive compression/decompression or modest 

compression/decompression. However, other embodiments may implement 
other modifications and variations on the user interface 312. For example, the 
user interface 312 may collect information other than stated above, such as 
whether the user prefers to receive or transmit audio, video or data samples 

1 5 from/to a specific caller/recipient or in a specific period of time with high quality 
and speed. Then, the policy maker 314 may translate the information Into a 
corresponding header policy. 
[0026] The predefined rule database 313 may store predefined rules on header 
compression/decompression setup during the configuration phase of the 

20 header compress/decompress framework 1 01 . For example, a company 
owning the IP device 1 13/123 may setup the predefined rule database and 
predefine whether and how to compress or decompress the IP packets 
transmitted from/to the company. 

* 

[0027] The policy maker 314 may make a header policy based upon the various 
25 factors collected by the collector 310. The header policy may determine 
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whether or not headers of IP packets input to the header 
compress/decompress framework 101 should be compressed/decompressed. 
The header policy may further determine a manner to compress/decompress 
the headers of the IP packets, e.g., a proactive or modest 
5 compression/decompression. For example, the policy maker may make a 

header non-compression/decompression policy for specific IP packets (e.g., IP 

* 

packets from/to a specific caller/recipient or transceived in a specific period of 
time) if the sensor 31 1 senses the network is a wireless and low speed 
network, or the IP packets are video packets, or any network device that may 

10 route the IP packets is unaware of compressed headers, which makes the 

header compression/decompression meaningless; or if the user interface 312 
shows the user prefers the headers of the specific IP packets uncompressed 
or un-decompressed; or if the predefined rule database 313 says so. For 
another example, the policy maker 314 may make a proactive header 

1 5 compression/decompression policy for the specific IP packets if the sensor 31 1 
senses the network is a fixed wired and high speed network, or the IP packets 
are audio packets having redundant information in the header fields; or if the 
user interface 312 shows the user prefers a proactive header 
compression/decompression policy; or if the predefined rule database 313 

20 says so. For still another example, the policy maker 314 may make a modest 
header compression/decompression policy for the specific IP packets if the 
sensor 31 1 senses the network is a low speed network but the IP packets are 
header overloaded which may worsen the packets transmission; or if the user 

* 

interface 312 shows the user prefers a modest header 
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compression/decompression policy; or if the predefined rule database 31 3 
says so. 

[0028] The policy maker 31 4 may further adjust a header policy based upon 

feedback from the compress/decompress logic 37 indicating how the header 
5 compression/decompression goes on for previous IP packets. 
[0029] The policy maker 314 may further translate the header policy into 

parameters to help the filter configuration logic 32 configure corresponding 
filter(s), such as upper traffic filter 33, upper configuration filter 34, lower traffic 
filter 35 or lower configuration filter 36. The parameters may comprise traffic 
1 0 parameters and compression/decompression parameters. The traffic 

parameters may help the upper traffic filter 33 to determine whether to deliver 
the IP packets to the compress/decompress logic 37 for header 
compression/decompression, or output the IP packets without header 
compression/decompression, or help the lower traffic filter 35 to determine 
1 5 whether to discard or output the IP packets from the compress/decompress 
logic. The compression/decompression parameters may help the 
compress/decompress logic 37 to compress or decompress the IP packets 
delivered from the upper traffic filter 33 in a manner specified by the header 
policy, such as proactively or modestly, and may be delivered to the 
20 compress/decompress logic 37 through the upper configuration filter 34 and/or 

lower configuration filter 36. 
[0030] The compress/decompress logic 37 may compress/decompress the IP 
packets not only based upon an existing compression/decompression 
mechanism such as CTCP, CRTP, ROHC, etc., but also base upon the 

25 compression/decompression parameters. The existing 
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compression/decompression mechanism may take advantage of the fact that it 
is not necessary to send static header fields in every packet because they do 
not change during a session, and the so-called 'changing fields' can be 
predicted from previous packets using a simple linear extrapolation, to perform 
5 the header compression/decompression. The compression/decompression 
parameters may reflect the header policy by, for example, determining how 
many IP packets with full header fields (i.e., uncompressed header fields) may 
be transmitted first and then start the header compression to trim the 
redundant header fields, or determining how to interpret the predictable 

10 'changing fields'. 
[0031 ] Other embodiments may implement other modifications and variations on 
the structure of the header compress/decompress framework as depicted in 
Fig. 3. For example, the factor collector 310 may comprise one or more of the 
sensor 31 1, user interface 312, predefined rule database 313. For another 
1 5 example, the policy maker can make policies other than the header policy, 

such as packet encryption/decryption policy, packet signature policy, etc. For 
still another example, based upon the header policy, the filter configuration 
logic 32 may configure any number of the upper traffic filter 33, upper 
configuration filter 34, lower traffic filter 35 and lower configuration filter 36. 
20 More specifically, the upper configuration filter 34 and/or lower configuration 
filter 36 may be omitted if the policy maker send the 

compression/decompression parameters directly to the compress/decompress 
logic or if no compression/decompression parameters are generated. The 
upper traffic filter 33 and/or lower traffic filter 34 may be omitted if no traffic 

p 

25 parameters are generated. ■ 
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[0032] An embodiment of a header compression/decompression method 

implemented by the header compress/decompress framework 101 is depicted 
in Fig. 4. 

[0033] In block 401 , two terminals in the two endpoints 1 1 and 1 2 may start audio, 
5 video or data communication with each other. In block 402, the factor collector 
310 of the header compress/decompress framework 101 in one terminal may 
collect factor(s) that may influence the header policy, for example, through 
sensing the characteristics of the network 14 and/or IP packets, interacting 
with the terminal user, checking the predefined rule database, detecting 
1 0 feedback of the compress/decompress logic 37, etc. Then, in block 403, the 
policy maker 314 may dynamically make a header policy based upon the 
collected factors. For example, the header policy may determine whether and 
how to compress/decompress headers of IP packets input to the header 
compress/decompress framework 101 . The header policy may further 
1 5 determine how to process the IP packets after header 
compression/decompression. 
[0034] In block 404, the policy maker 31 or filter configuration logic 32 may 
translate the header policy into parameters that the filters or 
compress/decompress logic may rely on for implementation, for example, the 
20 traffic parameters or compression/decompression parameters. In block 405, 
the filter configuration logic 32 may configure any number of filters 
corresponding to the header policy. For example, the filter configuration logic 
32 may configure upper traffic filter 33 and lower traffic filter 35 if the header 
policy refers to whether or not to compress/decompress the headers of the IP 
25 packets , and whether to output or discard the IP packets after header 

13 
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compression/decompression. The filter configuration logic 32 may configure 
upper configuration filter 34 and/or lower configuration filter 36 if the header 
policy refers to how to compress/decompress the headers of the IP packets. 
[0035] Then, the header compress/decompress framework 1 01 may receive an IP 

5 packet from the frame constructor/extractor 1 00 or from the network 1 4 (block 
406) and determine whether to compress/decompress a header of the IP 
packet based upon the header policy (block 407). In response to the header 
policy indicating that the header of IP packet should be 
compressed/decompressed, the upper traffic filter 33 may deliver the IP 

1 o packet to the compress/decompress logic 37 for header 
compression/decompression with reference to the 
compression/decompression parameters translated from the header policy 
(block 408). However, in response to the header policy indicating that the 
header of the IP packet should not be compressed/decompressed, the upper 

1 5 traffic filter 33 may bypass the compress/decompress logic 37 and output the 
IP packets without header compression/decompression (block 41 1). 
[0036] In block 409, the lower traffic filter 35 may determine whether to output or 
discard the IP packet after header compression/decompression. For example, 
the lower traffic filter 35 may determine to discard the IP packet if code error of 

20 the IP packet goes beyond a tolerance limit or a computed checksum does not 
match what the IP packet claims. Based upon the decision, the lower traffic 
filter 35 may discard the IP packet (block 410) or output the IP packet (block 
411). 

[0037] While certain features of the invention have been described with reference 
25 to example embodiments, the description is not intended to be construed in a 
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limiting sense. Various modifications of the example embodiments, as well as 
other embodiments of the invention, which are apparent to persons skilled in 
the art to which the invention pertains are deemed to lie within the spirit and 
scope of the invention. 
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